#!/usr/bin/bash

# Copyright (c) 2023. Huawei Technologies Co.,Ltd.ALL rights reserved.
# This program is licensed under Mulan PSL v2.
# You can use it according to the terms and conditions of the Mulan PSL v2.
#          http://license.coscl.org.cn/MulanPSL2
# THIS PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
# EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
# MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
# See the Mulan PSL v2 for more detaitest -f.

# #############################################
# @Author    :   linjianbo
# @Contact   :   jianbo.lin@outlook.com
# @Date      :   2023/07/28
# @License   :   Mulan PSL v2
# @Desc      :   test psselect
# #############################################

source "${OET_PATH}"/libs/locallibs/common_lib.sh

function pre_test() {
    LOG_INFO "Start environmental preparation."
    DNF_INSTALL psutils
    version=$(rpm -qa psutils | awk -F "-" '{print$2}')
    LOG_INFO "End of environmental preparation!"
}

function run_test() {
    LOG_INFO "Start to run test."

    # test psselect
    test "$(psselect --version 2>&1 | awk 'NR==1{print$2}')" == "$version"
    CHECK_RESULT $? 0 0 "psselect -v execution failed."
    psselect -o ./common/a4-11.ps | grep -a -i -E "%%Page: \(\d*[13579]\)"
    CHECK_RESULT $? 0 0 "psselect -o ./common/a4-11.ps execution failed."
    psselect -e ./common/a4-11.ps | grep -a -i -E "%%Page: \(\d*[02468]\)"
    CHECK_RESULT $? 0 0 "psselect -e ./common/a4-11.ps execution failed."
    psselect -p1 -p2 -p4 ./common/a4-11.ps 2>&1 | grep -a -i "wrote .* pages"
    CHECK_RESULT $? 0 0 "psselect -p1 -p2 -p4 ./common/a4-11.ps execution failed."
    psselect -r ./common/a4-2.ps 2>&1 | grep -i -a "wrote .* pages"
    CHECK_RESULT $? 0 0 "psselect -r ./common/a4-2.ps execution failed."
    psselect -r -q ./common/a4-2.ps 2>&1 | grep -i -a "wrote .* pages"
    CHECK_RESULT $? 0 0 "psselect -r -q ./common/a4-11.ps execution failed."

    LOG_INFO "End of the test."
}

function post_test() {
    LOG_INFO "start environment cleanup."
    DNF_REMOVE "$@"
    LOG_INFO "Finish environment cleanup!"
}

main "$@"
